草庐IT

1.9 桶排序

全部标签

ruby-on-rails - Ruby/Rails 中的整数排序

我正在寻找一种在Ruby/Rails中处理整数序号的方法,即。“st”、“nd”、“rd”和“th”是整数的后缀。RubyonRails曾经使用“ordinalize”方法扩展FixNum,但该功能似乎在版本3中已被弃用。我目前只是在使用旧Rails方法的源代码,这很好......但这似乎是大多数脚本语言/网络框架内置的功能,我觉得Rails背后的人一定有弃用该功能的原因(也许它现在在Ruby中可用?)。请指教! 最佳答案 你要的方法还是ordinalize.Active_Support进行了一些重构以提供更好的粒度。您可以根据需要

ruby - 为 ruby​​ 1.9 设置全局默认编码

我想告诉ruby​​一切都是utf8,除非另有说明,所以我不必到处放置这些#encoding:utf-8注释。 最佳答案 您可以:将您的RUBYOPT环境变量设置为“-Eutf-8”或使用https://github.com/m-ryan/magic_encoding 关于ruby-为ruby​​1.9设置全局默认编码,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5908774

ruby-on-rails - ruby 排序数组的数组

我在弄清楚如何对数组的数组进行排序时遇到问题。两个数组都很简单,我相信它很简单,但我似乎无法弄明白。这是数组:[["happy",1],["sad",2],["mad",1],["bad",3],["glad",12]]我想按内部数组的整数值对它进行排序,该整数值是单词出现次数的值,最大的在前。 最佳答案 试试:array=[["happy",1],["sad",2],["mad",1],["bad",3],["glad",12]]sorted=array.sort{|a,b|a[1]b[1]}或者:array=[["happy",

Ruby 1.9、YAML 和字符串编码 : how to lead a life of sanity?

在我看来,ruby1.9附带的YAML库是编码失聪的。这意味着在生成YAML时,它将采用任何字节串,并转义任何不输出干净ASCII的字节序列。这很蹩脚,但可以接受。我的问题恰恰相反。从所述YAML转储加载内容时。在下面的示例中,我创建了一个UTF-8字符串,将其转储为!binary类型。当我加载它时,它的编码是ASCII-8BIT。在示例的最后,我尝试将原始字符串和重新加载的字符串与另一个UTF-8字符串连接起来。后者将因Encoding::CompatibilityError而失败。require'yaml's0="Iñtërnâtiônàlizætiøn"y=s0.to_yamls

ruby - Ruby 1.9 正则表达式是否与上下文无关语法同样强大?

我有这个正则表达式:regex=%r{\A(?a\ga|b\gb|c)\Z}x当我针对多个字符串测试它时,它似乎与上下文无关语法一样强大,因为它正确地处理了递归。regex.match("aaacaaa")#=>#regex.match("aacaa")#=>#regex.match("aabcbaa")#=>#regex.match("aaacaa")#=>nil"FunwithRuby1.9RegularExpressions"有一个例子,他实际上安排了一个正则表达式的所有部分,使其看起来像一个上下文无关的语法,如下所示:sentence=%r{(?cat|dog|gerbil){

ruby-on-rails - Ruby 1.9 还不支持 Unicode 规范化

我正在尝试将我的一些旧Rails应用程序移植到Ruby1.9,但我不断收到关于“Ruby1.9还不支持Unicode规范化”的警告。我已经追踪到这个函数,但每个请求我收到大约20条警告消息:rails-2.3.5/activesupport/lib/active_support/inflector.rbdeftransliterate(string)warn"Ruby1.9doesn'tsupportUnicodenormalizationyet"string.dupend关于我应该如何开始追踪并解决这些问题有什么想法吗? 最佳答案

ruby - ruby 中的版本排序(使用 alphas、betas 等)

如何在Ruby中对版本列表进行排序?我看过有关自然排序的内容,但这是更进一步的内容。输入是一串这样的字符串:input=['10.0.0b12','10.0.0b3','10.0.0a2','9.0.10','9.0.3']我几乎可以用naturally做到这一点gem:require'naturally'Naturally.sort(input)=>["9.0.3","9.0.10","10.0.0a2","10.0.0b12","10.0.0b3"]问题:10.0.0b3排在10.0.0b12之后;10.0.0b3应该是第一个。谁有可行的方法?其他语言也有帮助!

ruby 1.9 如何将数组转换为不带括号的字符串

我的问题是关于如何在没有括号和引号的情况下在ruby​​1.9中将数组元素转换为字符串。我有一个数组(数据库提取),我想用它来创建定期报告。myArray=["Apple","Pear","Banana","2","15","12"]在ruby​​1.8中,我有以下行reportStr="Inthefirstquarterwesold"+myArray[3].to_s+""+myArray[0].to_s+"(s)."putsreportStr产生(想要的)输出Inthefirstquarterwesold2Apple(s).ruby1.9中相同的两行产生(不需要)Inthefirst

ruby 1.9 : Regular Expressions with unknown input encoding

在输入编码未知的Ruby1.9中,是否有一种公认的方法来处理正则表达式?假设我的输入恰好是UTF-16编码的:x="foobarbaz"y=x.encode('UTF-16LE')re=/(.*)/x.match(re)=>#bar"1:"bar">y.match(re)Encoding::CompatibilityError:incompatibleencodingregexpmatch(US-ASCIIregexpwithUTF-16LEstring)我目前的方法是在内部使用UTF-8并在必要时重新编码(副本)输入:ify.methods.include?(:encode)#Rub

ruby - Ruby 1.9 中新的散列语法有什么好处?

除了使以符号作为键定义散列看起来更简洁之外,将散列写为还有其他好处吗:{key1:"value1",key2:"value2"}而不是{:key1=>"value1",:key2=>"value2"}?此外,当您混合使用字符串和符号作为哈希键时,约定是什么?你是把它写成{"key1"=>"value1",key2:"value2"}还是保持风格一致{"key1"=>"value1",:key=>"value2"} 最佳答案 只是看起来更好——它是语法糖;它最终是同一件事。当混合键时(呃,你为什么要那样做?)我对整个哈希使用旧的哈希火